位运算之十进制转二进制 十六进制转二进制

利用位运算进行进制间的转换
#include <stdio.h>
#include <string.h>

int inttoBin(unsigned int num)
{
	int i;
	unsigned int mask = 0x80000000;
	for(i = 0; i < 32; i++)
	{
		if((num & mask) == mask)
		{
			printf("1");
		}
		
		else
		{
			printf("0");
		}

		num = num << 1;
		
		if((i + 1) % 4 ==0)
		{
			printf(" ");
		}
	}
	
	printf("\n");
}

int inttoox(unsigned int num)
{
	int i;
	unsigned int temp = num;

	char s[11];
	memset(s,0,sizeof(char));
	
	s[0] = "0";
	s[1] = "x";
	s[10] = "\0";

	unsigned int mask = 0x0000000f;

	for(i = 2; i < 10; i++)
	{
		if((temp & mask) > 10)
		{
			s[11-i] = (temp & mask) - 10 + 'a'; 
		}
		else
		{
			s[11-i] = (temp & mask) + '0';
		}
		
		temp = temp << 4;
	}
	
    printf("result = %s\n",s);
	//printf("result = %s\n",s);
}

int main()
{
	unsigned int num;
	char s[11];
	
	printf("intput a number\n");
	scanf("%u",&num);
	
	inttoBin(num);
	inttoox(num);

	return 0;
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
将十进制换成二进制可以使用移位运算和位与运算来实现。 具体步骤如下: 1. 将十进制数不断右移,直到为0,得到每一位的二进制数。 2. 将每一位的二进制数从右往左依次存储到一个数组中。 3. 对于两个二进制数相加,可以模拟竖式相加的过程。从右往左依次相加,如果相加的结果大于等于2,需要进位。 4. 对于进位的情况,可以使用位与运算和位异或运算来实现。位与运算可以得到需要进位的位,位异或运算可以得到不需要进位的位。 下面是一个示例代码: ```c #include <stdio.h> // 将十进制换成二进制 void decimalToBinary(int decimal, int binary[]) { int i = 0; while (decimal > 0) { binary[i] = decimal % 2; decimal /= 2; i++; } } // 将两个二进制数相加 void binaryAdd(int binary1[], int binary2[], int result[]) { int carry = 0; for (int i = 0; i < 32; i++) { int sum = binary1[i] + binary2[i] + carry; if (sum >= 2) { result[i] = sum - 2; carry = 1; } else { result[i] = sum; carry = 0; } } } // 输出二进制数 void printBinary(int binary[]) { int i; for (i = 31; i >= 0 && binary[i] == 0; i--); for (; i >= 0; i--) { printf("%d", binary[i]); } printf("\n"); } int main() { int decimal1 = 23; int decimal2 = 11; int binary1[32] = {0}; int binary2[32] = {0}; int result[32] = {0}; decimalToBinary(decimal1, binary1); decimalToBinary(decimal2, binary2); printf("Binary1: "); printBinary(binary1); printf("Binary2: "); printBinary(binary2); binaryAdd(binary1, binary2, result); printf("Result: "); printBinary(result); return 0; } ``` 输出结果如下: ``` Binary1: 10111 Binary2: 1011 Result: 100110 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值